home *** CD-ROM | disk | FTP | other *** search
/ Aminet 40 / Aminet 40 (2000)(Schatztruhe)[!][Dec 2000].iso / Aminet / misc / emu / ATUtilities.lha / ATUtilities / hg.c < prev    next >
C/C++ Source or Header  |  2000-09-26  |  40KB  |  1,647 lines

  1. /* ******************************************************************* */
  2. /* **                                                               ** */
  3. /* **                     ATUtilities Online Help                   ** */
  4. /* **            Copright (C) 1992-1993 by Thomas Dreibholz         ** */
  5. /* **                      All rights reserved                      ** */
  6. /* **                                                               ** */
  7. /* ******************************************************************* */
  8.  
  9. #define PAGE_INDEX 1
  10. #define PAGE_TEXT  2
  11.  
  12. #define PAGE_MEMORY 199
  13.  
  14. #include "ATUtilities.h"
  15. /*
  16. #define CreateBoolGadget(win,x,y,w,h,text,id) CreateBoolToggleGadget(0,win,x,y,w,h,text,id)
  17. #define CreateMinGadget(win,x,y,w,h,id) CreateBoolToggleGadget(4,win,x,y,w,h,0L,id)
  18. */
  19. extern struct Library *DiskfontBase;
  20.  
  21. /* feste Strukturen */
  22. UBYTE *HelpName= "SYS:PC/ATUtilities/OnlineHelp.prefs";
  23. UBYTE  st[]    = {0,1,3,4,7};
  24.  
  25. struct TextAttr Opal=
  26. {
  27.  "opal.font",
  28.  9,
  29.  FS_NORMAL,
  30.  FPF_DISKFONT
  31. };
  32.  
  33. struct OHPrefs
  34. {
  35.  UBYTE Cache;
  36.  UBYTE Numbers;
  37.  UBYTE NumInput;
  38.  UBYTE PAL;
  39. };
  40.  
  41. struct Page
  42. {
  43.  UWORD Length;
  44.  UWORD Flags;
  45.  ULONG Offset;
  46.  ULONG TextOffset;
  47.  ULONG GadgetOffset;
  48.  ULONG MenuOffset;
  49.  ULONG PictureOffset;
  50. };
  51.  
  52. struct Pages
  53. {
  54.  struct Page Page[1000];
  55. };
  56.  
  57. #define POFFSET(x) hd->Pages->Page[x].PictureOffset
  58. #define MOFFSET(x) hd->Pages->Page[x].MenuOffset
  59. #define GOFFSET(x) hd->Pages->Page[x].GadgetOffset
  60. #define TOFFSET(x) hd->Pages->Page[x].TextOffset
  61. #define OFFSET(x) hd->Pages->Page[x].Offset
  62. #define LENGTH(x) hd->Pages->Page[x].Length
  63. #define FLAGS(x) hd->Pages->Page[x].Flags
  64.  
  65. struct HelpData
  66. {
  67.  struct OHPrefs     OHPrefs;
  68.  struct Screen     *Screen;
  69.  struct Window     *MainWindow;
  70.  struct Window     *IndexWindow;
  71.  struct Window     *TextWindow;
  72.  struct MenuStrip  *MenuStrip;
  73.  struct Menu       *DateiMenu;
  74.  struct Menu       *QVMenu;
  75.  struct Menu       *BilderMenu;
  76.  struct Window     *GadWindow;
  77.  struct Gadget     *PropGadget;
  78.  struct PropInfo   *PropInfo;
  79.  struct RastPort   *MainRastPort;
  80.  struct RastPort   *IndexRastPort;
  81.  struct MsgPort    *MainUserPort;
  82.  struct MsgPort    *IndexUserPort;
  83.  struct MsgPort    *TextUserPort;
  84.  struct MsgPort    *GadUserPort;
  85.  struct TextFont   *OpalFont;
  86.  struct ViewPort   *ViewPort;
  87.  struct MsgPort    *ConPort;
  88.  struct IOStdReq   *ConReq;
  89.  LONG               ConDev;
  90.  struct FileHandle *HelpFile;
  91.  UBYTE             *Memory;
  92.  struct Pages      *Pages;
  93.  ULONG              Picture[100];
  94.  UWORD              Page;
  95.  UWORD              Flags;
  96.  ULONG              MainWindowSM;
  97.  ULONG              IndexWindowSM;
  98.  ULONG              TextWindowSM;
  99.  ULONG              GadWindowSM;
  100.  ULONG              WaitSM;
  101.  UWORD              NextPage[4];
  102.  
  103.  UWORD              LastPage[PAGE_MEMORY+1];
  104.  UBYTE              LastPagePos;
  105.  UBYTE              LastPageSelect;
  106.  UWORD              ShowLastPageBack;
  107.  
  108.  UBYTE              String[200];
  109.  
  110.  BOOL               NTSC;
  111.  UWORD              Rows;
  112.  UWORD              MaxItems;
  113.  
  114.  UWORD              PropDown;
  115.  
  116.  UWORD              CacheOn;
  117.  ULONG              CacheSize;
  118.  LONG               CachePos;
  119.  LONG               CacheLastPos;
  120.  UBYTE             *CacheMemory;
  121.  
  122.  UBYTE              InputCount;
  123.  UWORD              Input[3];
  124.  
  125.  UWORD              IGy;
  126.  UWORD              IGw;
  127.  UWORD              IGs;
  128.  UWORD              IGPCount;
  129.  struct Gadget     *IndexGadgets[64];
  130.  UWORD              IndexGadgetPages[64];
  131.  
  132.  UWORD              MenuPageCount;
  133.  UWORD              MenuNames[25][62];
  134.  UWORD              MenuPages[25];
  135.  
  136.  UBYTE              MenuPicCount;
  137.  UBYTE              MenuPicNames[25][16];
  138.  UBYTE              MenuPics[25];
  139.  
  140.  UWORD              PropBody;
  141.  UWORD              LineCount;
  142.  UWORD              CurrentLine;
  143.  UBYTE             *Lines[2000];
  144.  
  145.  UWORD              OutputPos;
  146. };
  147.  
  148. UWORD Colors[]={0x97a,0x222,0xddd,0xff5,0xdd6,0xccc,0xfff,0x22f};
  149.  
  150. BOOL OpenHelp();
  151. VOID CloseHelp();
  152. VOID ConWrite();
  153. VOID RefreshGadWindow();
  154. VOID GetTitle();
  155. VOID LoadPage();
  156. VOID ShowIndexPage();
  157. VOID ShowTextPage();
  158. VOID RemIndexGadgets();
  159. VOID NewProp();
  160. VOID ShowPart();
  161. VOID MakeMenu();
  162. VOID Special();
  163. VOID GetPictures();
  164. VOID GetItems();
  165. VOID Prefs();
  166. LONG CacheRead();
  167. LONG CacheSeek();
  168. VOID LoadAPicture();
  169. VOID AddPage();
  170.  
  171.  
  172. /* Informationen anzeigen */
  173. VOID ShowInfo(win,scr)
  174.  struct Window *win;
  175.  struct Screen *scr;
  176. {
  177.  ScreenInformationBox(scr,
  178.                       "ATUtilities Online Help - Information",
  179.                       "Online Help - Version 2.0",
  180.                       "Copyright (C) 1993 by",
  181.                       "Thomas Dreibholz",
  182.                       "All rights reserved.",
  183.                       "SYS:PC/ATUtilities/Icons/Help");
  184.  ActivateWindow(win);
  185. }
  186.  
  187.  
  188. /* Online-Hilfe-Funktion */
  189. VOID Help(name,seite)
  190.  UBYTE *name;
  191.  UWORD  seite;
  192. {
  193.  UBYTE                         s[32];
  194.  REGISTER ULONG                Class;
  195.  REGISTER BOOL                 ende,bool;
  196.  REGISTER UWORD                i,j,Code;
  197.  REGISTER UWORD                MenuNum,ItemNum;
  198.  REGISTER ULONG                Signale;
  199.  register struct IntuiMessage *msg;
  200.  register struct HelpData     *hd;
  201.  register struct Gadget       *gad;
  202.  
  203.  if(DiskfontBase==NULL)
  204.   {
  205.    InfoRequest("Keine Diskfont-Library!");
  206.    return;
  207.   }
  208.  
  209.  hd=AllocMem(sizeof(struct HelpData),MEMF_CLEAR|MEMF_PUBLIC);
  210.  if(hd==NULL)
  211.   {
  212.    ErrorRequest(ERROR_ALLOC);
  213.    return;
  214.   }
  215.  
  216.  bool=OpenHelp(hd,name);
  217.  if(bool==TRUE)
  218.   {
  219.    ende=FALSE;
  220.    while(ende==FALSE)
  221.     {
  222.      Signale=Wait(hd->WaitSM);
  223.      if((hd->GadUserPort!=NULL) && (Signale & hd->GadWindowSM))
  224.       {
  225.        msg=GetMsg(hd->GadUserPort);
  226.        while(msg!=NULL)
  227.         {
  228.          Class=msg->Class;
  229.          gad=msg->IAddress;
  230.          ReplyMsg(msg);
  231.          if(Class==GADGETUP)
  232.           {
  233.            j=gad->GadgetID;
  234.            switch(j)
  235.             {
  236.              case 1000:
  237.                if(hd->LastPageSelect>0)
  238.                 {
  239.                  if(!(hd->Page==1001))
  240.                   {
  241.                    hd->LastPageSelect--;
  242.                    hd->ShowLastPageBack++;
  243.                   }
  244.                  LoadPage(hd,hd->LastPage[hd->LastPageSelect],FALSE);
  245.                 }
  246.               break;
  247.              case 2000:
  248.                if(hd->ShowLastPageBack>0)
  249.                 {
  250.                  hd->ShowLastPageBack--;
  251.                  hd->LastPageSelect++;
  252.                  LoadPage(hd,hd->LastPage[hd->LastPageSelect],FALSE);
  253.                 }
  254.               break;
  255.              default:
  256.                LoadPage(hd,hd->NextPage[j],TRUE);
  257.               break;
  258.             }
  259.           }
  260.          else if(Class==ACTIVEWINDOW)
  261.            ActivateWindow(hd->MainWindow);
  262.          msg=GetMsg(hd->GadUserPort);
  263.         }
  264.       }
  265.      if(Signale & hd->MainWindowSM)
  266.       {
  267.        msg=GetMsg(hd->MainUserPort);
  268.        while(msg!=NULL)
  269.         {
  270.          Class=msg->Class;
  271.          Code=msg->Code;
  272.          gad=msg->IAddress;
  273.          ReplyMsg(msg);
  274.          switch(Class)
  275.           {
  276.            case GADGETUP:
  277.             j=gad->GadgetID;
  278.             switch(j)
  279.              {
  280.               case 1:
  281.                 ende=TRUE;
  282.                break;
  283.               case 2:
  284.                 LoadPage(hd,0,TRUE);
  285.                break;
  286.               case 3:
  287.                 if((hd->Flags==PAGE_TEXT)&&(hd->LineCount>hd->Rows))
  288.                  {
  289.                   hd->PropDown=0;
  290.                   j=hd->PropInfo->VertPot/(65535/hd->PropBody);
  291.                   ShowPart(hd,j);
  292.                  }
  293.                break;
  294.              }
  295.             break;
  296.            case GADGETDOWN:
  297.             j=gad->GadgetID;
  298.             switch(j)
  299.              {
  300.               case 3:
  301.                 if((hd->Flags==PAGE_TEXT)&&(hd->LineCount>hd->Rows))
  302.                  {
  303.                   hd->PropDown=1;
  304.                  }
  305.                break;
  306.              }
  307.             break;
  308.            case MOUSEMOVE:
  309.              if(hd->PropDown!=0)
  310.               {
  311.                AbortIO(hd->ConReq);
  312.                j=hd->PropInfo->VertPot/(65535/hd->PropBody);
  313.                ShowPart(hd,j);
  314.               }
  315.             break;
  316.            case MENUPICK:
  317.              MenuNum=MENUNUM(Code);
  318.              ItemNum=ITEMNUM(Code);
  319.              switch(MenuNum)
  320.               {
  321.                case 2:
  322.                  switch(ItemNum)
  323.                   {
  324.                    case 0:
  325.                      ende=TRUE;
  326.                     break;
  327.                    case 2:
  328.                      ShowInfo(hd->MainWindow,hd->Screen);
  329.                     break;
  330.                    case 4:
  331.                      Special(hd,1);
  332.                     break;
  333.                    case 5:
  334.                      Special(hd,2);
  335.                     break;
  336.                    case 6:
  337.                      Special(hd,3);
  338.                     break;
  339.                    case 8:
  340.                      Prefs(hd);
  341.                     break;
  342.                   }
  343.                 break;
  344.                case 1:
  345.                  if((hd->MenuPageCount!=0)&&(ItemNum<=hd->MenuPageCount))
  346.                    LoadPage(hd,hd->MenuPages[hd->MenuPageCount-ItemNum-1],TRUE);
  347.                 break;
  348.                case 0:
  349.                  if((hd->MenuPicCount!=0)&&(ItemNum<=hd->MenuPicCount))
  350.                    LoadAPicture(hd,hd->MenuPics[hd->MenuPicCount-ItemNum-1]);
  351.                  ActivateWindow(hd->MainWindow);
  352.                 break;
  353.               }
  354.             break;
  355.            case VANILLAKEY:
  356.              if(hd->OHPrefs.NumInput)
  357.               {
  358.                if((Code>='0')&&(Code<='9'))
  359.                 {
  360.                  hd->Input[hd->InputCount]=Code;
  361.                  hd->InputCount++;
  362.                  sprintf(&s,"Seiteneingabe: #%c%c%c",hd->Input[0],
  363.                                                      hd->Input[1],
  364.                                                      hd->Input[2]);
  365.                  DrawCNTextBorder(hd->MainWindow,320,10,310,12,&s);
  366.                  if(hd->InputCount>2)
  367.                   {
  368.                    LoadPage(hd,(hd->Input[0]-48)*100+
  369.                                (hd->Input[1]-48)*10+
  370.                                (hd->Input[2]-48),TRUE);
  371.                   }
  372.                 }
  373.               }
  374.             break;
  375.           }
  376.          msg=GetMsg(hd->MainUserPort);
  377.         }
  378.       }
  379.      if(Signale & hd->IndexWindowSM)
  380.       {
  381.        msg=GetMsg(hd->IndexUserPort);
  382.        while(msg!=NULL)
  383.         {
  384.          Class=msg->Class;
  385.          gad=msg->IAddress;
  386.          ReplyMsg(msg);
  387.          if(Class==GADGETUP)
  388.           {
  389.            j=gad->GadgetID;
  390.            LoadPage(hd,hd->IndexGadgetPages[j],TRUE);
  391.           }
  392.          else if(Class==ACTIVEWINDOW)
  393.            ActivateWindow(hd->MainWindow);
  394.          msg=GetMsg(hd->IndexUserPort);
  395.         }
  396.       }
  397.      if(Signale & hd->TextWindowSM)
  398.       {
  399.        msg=GetMsg(hd->TextUserPort);
  400.        while(msg!=NULL)
  401.         {
  402.          Class=msg->Class;
  403.          ReplyMsg(msg);
  404.          if(Class==ACTIVEWINDOW)
  405.            ActivateWindow(hd->MainWindow);
  406.          msg=GetMsg(hd->TextUserPort);
  407.         }
  408.       }
  409.     }
  410.   }
  411.  CloseHelp(hd);
  412.  FreeMem(hd,sizeof(struct HelpData));
  413. }
  414.  
  415.  
  416. /* Hilfe starten */
  417. BOOL OpenHelp(hd,name)
  418.  struct HelpData *hd;
  419.  UBYTE           *name;
  420. {
  421.  register struct FileHandle *fh;
  422.  UBYTE                       c;
  423.  WORD                        a,i;
  424.  LONG                        b;
  425.  static struct NewScreen HelpScreen=
  426.   {
  427.    0,0,640,256,3,
  428.    0,1,
  429.    HIRES,
  430.    CUSTOMSCREEN,
  431.    NULL,
  432.    NULL,NULL,NULL
  433.   };
  434.  static struct NewWindow MainWindowDef=
  435.   {
  436.    0,0,640,256,
  437.    0,2,
  438.    GADGETUP|MENUPICK|GADGETDOWN|MOUSEMOVE|VANILLAKEY,
  439.    ACTIVATE|BORDERLESS,
  440.    NULL,NULL,NULL,NULL,NULL,
  441.    10,16,640,256,
  442.    CUSTOMSCREEN
  443.   };
  444.  static struct NewWindow IndexWindowDef=
  445.   {
  446.    11,26,582,210,
  447.    0,1,
  448.    GADGETUP|ACTIVEWINDOW,
  449.    BORDERLESS,
  450.    NULL,NULL,NULL,NULL,NULL,
  451.    10,16,640,256,
  452.    CUSTOMSCREEN
  453.   };
  454.  static struct NewWindow TextWindowDef=
  455.   {
  456.    12,27,580,208,
  457.    0,1,
  458.    ACTIVEWINDOW,
  459.    NOCAREREFRESH|BORDERLESS,
  460.    NULL,NULL,NULL,NULL,NULL,
  461.    10,16,640,256,
  462.    CUSTOMSCREEN
  463.   };
  464.  
  465.  hd->ConDev=-1L;
  466.  
  467.  hd->HelpFile=Open(name,MODE_OLDFILE);
  468.  if(hd->HelpFile==NULL)
  469.   {
  470.    MultiRequest("Kann Hilfedatei nicht öffnen:",name,"Okay",NULL);
  471.    return(FALSE);
  472.   }
  473.  
  474.  hd->OpalFont=GetOpalFont();
  475.  if(hd->OpalFont==NULL)
  476.   {
  477.    InfoRequest("Opal-Font fehlt!");
  478.    return(FALSE);
  479.   }
  480.  
  481.  fh=Open(HelpName,MODE_OLDFILE);
  482.  if(fh!=NULL)
  483.   {
  484.    Read(fh,&hd->OHPrefs,sizeof(struct OHPrefs));
  485.    Close(fh);
  486.   }
  487.  
  488.  if(hd->OHPrefs.PAL==0)
  489.   {
  490.    hd->NTSC=TRUE;
  491.    hd->Rows=18;
  492.    hd->MaxItems=18;
  493.    HelpScreen.Height=200;
  494.    MainWindowDef.Height=200;
  495.    IndexWindowDef.Height=154;
  496.    TextWindowDef.Height=152;
  497.   }
  498.  else
  499.   {
  500.    hd->NTSC=FALSE;
  501.    hd->Rows=25;
  502.    hd->MaxItems=24;
  503.   }
  504.  
  505.  hd->Screen=OpenScreen(&HelpScreen);
  506.  if(hd->Screen==NULL)
  507.   {
  508.    InfoRequest("Kann Screen nicht öffnen!");
  509.    return(FALSE);
  510.   }
  511.  
  512.  hd->ViewPort=&hd->Screen->ViewPort;
  513.  LoadRGB4(hd->ViewPort,&Colors,8);
  514.  
  515.  MainWindowDef.Screen=hd->Screen;
  516.  IndexWindowDef.Screen=hd->Screen;
  517.  TextWindowDef.Screen=hd->Screen;
  518.  
  519.  hd->IndexWindow=OpenWindow(&IndexWindowDef);
  520.  if(hd->IndexWindow==NULL)
  521.   {
  522.    InfoRequest("Kann Fenster nicht öffnen!");
  523.    return(FALSE);
  524.   }
  525.  
  526.  hd->TextWindow=OpenWindow(&TextWindowDef);
  527.  if(hd->TextWindow==NULL)
  528.   {
  529.    InfoRequest("Kann Fenster nicht öffnen!");
  530.    return(FALSE);
  531.   }
  532.  
  533.  hd->MainWindow=OpenWindow(&MainWindowDef);
  534.  if(hd->MainWindow==NULL)
  535.   {
  536.    InfoRequest("Kann Fenster nicht öffnen!");
  537.    return(FALSE);
  538.   }
  539.  
  540.  hd->MainRastPort=hd->MainWindow->RPort;
  541.  hd->IndexRastPort=hd->IndexWindow->RPort;
  542.  hd->MainUserPort=hd->MainWindow->UserPort;
  543.  hd->IndexUserPort=hd->IndexWindow->UserPort;
  544.  hd->TextUserPort=hd->TextWindow->UserPort;
  545.  hd->MainWindowSM=(1L<<hd->MainUserPort->mp_SigBit);
  546.  hd->IndexWindowSM=(1L<<hd->IndexUserPort->mp_SigBit);
  547.  hd->TextWindowSM=(1L<<hd->TextUserPort->mp_SigBit);
  548.  hd->MainWindow->UserData=NULL;
  549.  hd->IndexWindow->UserData=NULL;
  550.  hd->TextWindow->UserData=NULL;
  551.  
  552.  SetFont(hd->MainRastPort,hd->OpalFont);
  553.  SetFont(hd->IndexRastPort,hd->OpalFont);
  554.  
  555.  CreateBoolGadget(hd->MainWindow,10,10,150,12,"Ende",1);
  556.  CreateBoolGadget(hd->MainWindow,165,10,150,12,"Index",2);
  557.  if(hd->NTSC==FALSE) i=211; else i=155;
  558.  hd->PropGadget=CreatePropGadget(hd->MainWindow,600,25,30,i,0,0,0,65535,3);
  559.  hd->PropInfo=hd->PropGadget->SpecialInfo;
  560.  DrawNBorder(hd->MainWindow,10,25,584,i);
  561.  
  562.  SetAPen(hd->MainRastPort,3);
  563.  WriteText(hd->MainRastPort,40,40,"ATUtilities Online-Hilfe - Version 2.0");
  564.  WriteText(hd->MainRastPort,40,60,"Hilfedatei wird bearbeitet.");
  565.  WriteText(hd->MainRastPort,40,80,"Bitte warten...");
  566.  
  567.  hd->ConPort=CreatePort("onlinehelp-console.port",0L);
  568.  if(hd->ConPort==NULL)
  569.   {
  570.    InfoRequest("Kann MsgPort nicht erstellen!");
  571.    return(FALSE);
  572.   }
  573.  
  574.  hd->ConReq=CreateExtIO(hd->ConPort,sizeof(struct IOStdReq));
  575.  if(hd->ConReq==NULL)
  576.   {
  577.    InfoRequest("Kann IOStdReq nicht erstellen!");
  578.    return(FALSE);
  579.   }
  580.  
  581.  hd->ConReq->io_Data=hd->TextWindow;
  582.  hd->ConReq->io_Length=sizeof(struct Window);
  583.  
  584.  hd->ConDev=OpenDevice("console.device",0L,hd->ConReq,0L);
  585.  if(hd->ConDev!=0)
  586.   {
  587.    InfoRequest("Kann Console-Device nicht öffnen!");
  588.    return(FALSE);
  589.   }
  590.  ConWrite(hd,"\x9b0;33;40m");
  591.  
  592.  if(hd->OHPrefs.Cache!=0)
  593.   {
  594.    Seek(hd->HelpFile,0,OFFSET_END);
  595.    hd->CacheSize=Seek(hd->HelpFile,0,OFFSET_BEGINNING);
  596.    hd->CacheMemory=AllocMem(hd->CacheSize,MEMF_CLEAR|MEMF_PUBLIC);
  597.    if(hd->CacheMemory!=NULL)
  598.     {
  599.      b=Read(hd->HelpFile,hd->CacheMemory,hd->CacheSize);
  600.      if(b==hd->CacheSize) hd->CacheOn=1;
  601.     }
  602.   }
  603.  
  604.  hd->Pages=AllocMem(sizeof(struct Pages),MEMF_CLEAR|MEMF_PUBLIC);
  605.  if(hd->Pages==NULL)
  606.   {
  607.    ErrorRequest(ERROR_ALLOC);
  608.    return(FALSE);
  609.   }
  610.  
  611.  hd->Memory=AllocMem(50000,MEMF_CLEAR|MEMF_PUBLIC);
  612.  if(hd->Memory==NULL)
  613.   {
  614.    ErrorRequest(ERROR_ALLOC);
  615.    return(FALSE);
  616.   }
  617.  
  618.  CacheSeek(hd,-4,OFFSET_END);
  619.  CacheRead(hd,&b,4L);
  620.  CacheSeek(hd,b,OFFSET_BEGINNING);
  621.  for(i=0;i<1000;i++)
  622.   {
  623.    CacheRead(hd,&c,1L);
  624.    if(c!=0)
  625.     {
  626.      CacheRead(hd,&a,2L);
  627.      CacheRead(hd,&b,4L);
  628.      LENGTH(i)=a;
  629.      OFFSET(i)=b;
  630.      FLAGS(i)=c;
  631.      CacheRead(hd,&b,4L);
  632.      TOFFSET(i)=b;
  633.      CacheRead(hd,&b,4L);
  634.      GOFFSET(i)=b;
  635.      CacheRead(hd,&b,4L);
  636.      MOFFSET(i)=b;
  637.      CacheRead(hd,&b,4L);
  638.      POFFSET(i)=b;
  639.     }
  640.   }
  641.  for(i=0;i<100;i++)
  642.   {
  643.    CacheRead(hd,&hd->Picture[i],4L);
  644.   }
  645.  
  646.  hd->MenuStrip=BuildMenuStrip(hd->MainWindow,7,AUTOBACKPEN);
  647.  if(hd->MenuStrip==NULL)
  648.   {
  649.    InfoRequest("Kein Speicher für Menu!");
  650.    return(FALSE);
  651.   }
  652.  
  653.  hd->Page=12345;
  654.  LoadPage(hd,0,TRUE);
  655.  return(TRUE);
  656. }
  657.  
  658.  
  659. /* Hilfe beenden */
  660. VOID CloseHelp(hd)
  661.  struct HelpData *hd;
  662. {
  663.  
  664.  if(hd->MenuStrip) RemoveMenuStrip(hd->MenuStrip,TRUE);
  665.  if(hd->ConDev==0) CloseDevice(hd->ConReq);
  666.  if(hd->GadWindow) DeleteStdWindow(hd->GadWindow);
  667.  if(hd->TextWindow) DeleteStdWindow(hd->TextWindow);
  668.  if(hd->IndexWindow)
  669.   {
  670.    RemIndexGadgets(hd);
  671.    DeleteStdWindow(hd->IndexWindow);
  672.   }
  673.  if(hd->MainWindow) DeleteStdWindow(hd->MainWindow);
  674.  if(hd->Screen) CloseScreen(hd->Screen);
  675.  if(hd->ConReq) DeleteExtIO(hd->ConReq);
  676.  if(hd->ConPort) DeletePort(hd->ConPort);
  677.  if(hd->Pages) FreeMem(hd->Pages,sizeof(struct Pages));
  678.  if(hd->Memory) FreeMem(hd->Memory,50000);
  679.  if(hd->CacheMemory) FreeMem(hd->CacheMemory,hd->CacheSize);
  680.  if(hd->OpalFont) CloseFont(hd->OpalFont);
  681.  if(hd->HelpFile) Close(hd->HelpFile);
  682. }
  683.  
  684.  
  685. /* Text im Console-Display ausgeben */
  686. VOID ConWrite(hd,text)
  687.  struct HelpData *hd;
  688.  UBYTE           *text;
  689. {
  690.  hd->ConReq->io_Data=text;
  691.  hd->ConReq->io_Length=strlen(text);
  692.  hd->ConReq->io_Command=CMD_WRITE;
  693.  SendIO(hd->ConReq);
  694. }
  695.  
  696.  
  697. /* Gadget-Fenster erstellen */
  698. VOID RefreshGadWindow(hd)
  699.  struct HelpData *hd;
  700. {
  701.  WORD i;
  702.  static struct NewWindow GadWindowDef=
  703.   {
  704.    0,238,640,15,
  705.    0,1,
  706.    GADGETUP|ACTIVEWINDOW,
  707.    BORDERLESS,
  708.    NULL,NULL,NULL,NULL,NULL,
  709.    10,10,640,256,
  710.    CUSTOMSCREEN
  711.   };
  712.  
  713.  if(hd->NTSC==TRUE) GadWindowDef.TopEdge=182;
  714.  if(hd->GadWindow!=NULL)
  715.    DeleteStdWindow(hd->GadWindow);
  716.  GetTitle(hd,hd->Page);
  717.  DrawMNTextBorder(hd->MainWindow,320,10,310,12,hd->Memory);
  718.  
  719.  GadWindowDef.Screen=hd->Screen;
  720.  hd->GadWindow=OpenWindow(&GadWindowDef);
  721.  if(hd->GadWindow!=NULL)
  722.   {
  723.    SetFont(hd->GadWindow->RPort,hd->OpalFont);
  724.    hd->GadUserPort=hd->GadWindow->UserPort;
  725.    hd->GadWindowSM=(1L<<hd->GadUserPort->mp_SigBit);
  726.    for(i=0;i<=3;i++) hd->NextPage[i]=0xFFFF;
  727.  
  728.    if(hd->Page>0)
  729.     {
  730.      for(i=(hd->Page-1);i>=0;i--)
  731.        if(FLAGS(i)==PAGE_INDEX)
  732.         { hd->NextPage[0]=i; break; }
  733.     }
  734.  
  735.    if(hd->Page!=0) hd->NextPage[3]=0;
  736.    if(hd->Page<999)
  737.     {
  738.      for(i=(hd->Page+1);i<=999;i++)
  739.        if(FLAGS(i)==PAGE_INDEX)
  740.         { hd->NextPage[3]=i; break; }
  741.     }
  742.  
  743.    if(hd->Page>0)
  744.     {
  745.      for(i=(hd->Page-1);i>=0;i--)
  746.       {
  747.        if(FLAGS(i)!=0)
  748.         {
  749.          if(FLAGS(i)==PAGE_TEXT)
  750.            hd->NextPage[1]=i;
  751.          break;
  752.         }
  753.       }
  754.     }
  755.  
  756.    if(hd->Page<999)
  757.     {
  758.      for(i=(hd->Page+1);i<=999;i++)
  759.       {
  760.        if(FLAGS(i)!=0)
  761.         {
  762.          if(FLAGS(i)==PAGE_TEXT)
  763.            hd->NextPage[2]=i;
  764.          break;
  765.         }
  766.       }
  767.     }
  768.  
  769.    for(i=0;i<=3;i++)
  770.     {
  771.      if(hd->NextPage[i]!=0xFFFF)
  772.       {
  773.        GetTitle(hd,hd->NextPage[i]);
  774.        CreateMBoolGadget(hd->GadWindow,38+(i*143),1,135,12,hd->Memory,i);
  775.       }
  776.     }
  777.    if(hd->LastPageSelect>0)
  778.      CreateBoolGadget(hd->GadWindow,10,1,22,12,"«",1000);
  779.    if(hd->ShowLastPageBack>0)
  780.      CreateBoolGadget(hd->GadWindow,608,1,22,12,"»",2000);
  781.   }
  782.  else
  783.   {
  784.    hd->GadWindowSM=0;
  785.    hd->GadUserPort=NULL;
  786.   }
  787.  hd->WaitSM=hd->GadWindowSM+hd->MainWindowSM+hd->IndexWindowSM+hd->TextWindowSM;
  788. }
  789.  
  790.  
  791. /* Titel einer Seite ermitteln */
  792. VOID GetTitle(hd,p)
  793.  struct HelpData *hd;
  794.  LONG             p;
  795. {
  796.  LONG i,o;
  797.  
  798.  i=OFFSET(p);
  799.  if(i!=0)
  800.   {
  801.    o=CacheSeek(hd,i,OFFSET_BEGINNING);
  802.    if(hd->OHPrefs.Numbers==0)
  803.     {
  804.      CacheRead(hd,hd->Memory,1024L);
  805.     }
  806.    else
  807.     {
  808.      sprintf(hd->Memory,"#%03ld: ",p);
  809.      CacheRead(hd,&hd->Memory[6],1024L);
  810.     }
  811.    CacheSeek(hd,o,OFFSET_BEGINNING);
  812.   }
  813.  else hd->Memory[0]=0x00;
  814. }
  815.  
  816.  
  817. /* Seite anzeigen */
  818. VOID LoadPage(hd,num,add)
  819.  struct HelpData *hd;
  820.  UWORD            num;
  821.  BOOL             add;
  822. {
  823.  
  824.  hd->InputCount=0;
  825.  hd->Input[1]='-';
  826.  hd->Input[2]='-';
  827.  if(num==hd->Page) return;
  828.  if(OFFSET(num)!=0)
  829.   {
  830.    hd->Page=num;
  831.    hd->Flags=FLAGS(num);
  832.    if(add==TRUE) AddPage(hd);
  833.    RemIndexGadgets(hd);
  834.    switch(hd->Flags)
  835.     {
  836.      case PAGE_INDEX:
  837.        NewProp(hd,1);
  838.        ShowIndexPage(hd,num);
  839.       break;
  840.      case PAGE_TEXT:
  841.        ShowTextPage(hd,num);
  842.       break;
  843.     }
  844.   }
  845.  else
  846.   {
  847.    DisplayBeep(hd->Screen);
  848.    DisplayBeep(hd->Screen);
  849.   }
  850. }
  851.  
  852.  
  853. /* Indexseite anzeigen */
  854. VOID ShowIndexPage(hd,num)
  855.  struct HelpData *hd;
  856.  UWORD            num;
  857. {
  858.  UBYTE *m;
  859.  LONG   i,j,max;
  860.  UWORD  x,y,w,xx,yy;
  861.  UWORD  wort;
  862.  UBYTE  c;
  863.  
  864.  x=15; y=11;
  865.  j=TOFFSET(num);
  866.  if(j!=0)
  867.   {
  868.    i=LENGTH(num);
  869.    CacheSeek(hd,j,OFFSET_BEGINNING);
  870.    CacheRead(hd,hd->Memory,i);
  871.  
  872.  /* ----- Testausgabe -------------------------------------------------- */
  873.    SetAPen(hd->IndexRastPort,3);
  874.    m=hd->Memory;
  875.    for(j=0;j<i;j++)
  876.     {
  877.      c=m[j];
  878.      if(c==0x00)
  879.       {
  880.        x=15;
  881.        y+=10;
  882.       }
  883.      else
  884.       {
  885.        Move(hd->IndexRastPort,x,y);
  886.        Text(hd->IndexRastPort,&c,1L);
  887.        x=x+TextLength(hd->IndexRastPort,&c,1L);
  888.       }
  889.     }
  890.   }
  891.  
  892.  /* ----- Gadgets ------------------------------------------------------ */
  893.  j=GOFFSET(num);
  894.  if(j!=0)
  895.   {
  896.    CacheSeek(hd,j,OFFSET_BEGINNING);
  897.    j=0; y-=5;
  898.    CacheRead(hd,&wort,2L);
  899.    while((wort!=0xFFFF)&&(j<=63))
  900.     {
  901.      hd->IndexGadgetPages[j]=wort;
  902.      j++;
  903.      CacheRead(hd,&wort,2L);
  904.     }
  905.    hd->IGPCount=j;
  906.  
  907.    if(hd->NTSC==FALSE) max=198; else max=142;
  908.    hd->IGy=(max-y)/27;
  909.    if(hd->IGy==0) hd->IGy=1;
  910.    hd->IGs=hd->IGPCount/hd->IGy;
  911.    if(hd->IGs==0) hd->IGs=1;
  912.    hd->IGw=((552-((hd->IGs-1)*5))/hd->IGs);
  913.  
  914.    x=15;
  915.    for(i=0;i<hd->IGPCount;i++)
  916.     {
  917.      if(hd->IndexGadgetPages[i]!=2000)
  918.       {
  919.        GetTitle(hd,hd->IndexGadgetPages[i]);
  920.        hd->IndexGadgets[i]=CreateMBoolGadget(hd->IndexWindow,x,y,hd->IGw,12,hd->Memory,i);
  921.        x+=hd->IGw+5;
  922.        if(x>550) { x=15; y+=15; }
  923.       }
  924.      else
  925.       {
  926.        if(x>15)
  927.         {
  928.          x=15; y+=15;
  929.         }
  930.        y+=10;
  931.       }
  932.     }
  933.   }
  934.  else hd->IGPCount=0;
  935.  GetItems(hd,num);
  936.  GetPictures(hd,num);
  937.  
  938.  /* ----- GadWindow öffnen --------------------------------------------- */
  939.  
  940.  WindowToFront(hd->IndexWindow);
  941.  RefreshGadWindow(hd);
  942.  MakeMenu(hd);
  943. }
  944.  
  945.  
  946. /* Bilder laden */
  947. VOID GetPictures(hd,num)
  948.  struct HelpData *hd;
  949.  UWORD            num;
  950. {
  951.  UBYTE          byte;
  952.  REGISTER ULONG o;
  953.  
  954.  hd->MenuPicCount=0;
  955.  o=POFFSET(num);
  956.  if(o!=0)
  957.   {
  958.    CacheSeek(hd,o,OFFSET_BEGINNING);
  959.    CacheRead(hd,&byte,1L);
  960.    while((byte!=0xFF)&&(hd->MenuPicCount<=hd->MaxItems))
  961.     {
  962.      hd->MenuPics[hd->MenuPicCount]=byte;
  963.      hd->MenuPicCount++;
  964.      CacheRead(hd,&byte,1L);
  965.     }
  966.   }
  967. }
  968.  
  969.  
  970. /* Menü-Items laden */
  971. VOID GetItems(hd,num)
  972.  struct HelpData *hd;
  973.  UWORD            num;
  974. {
  975.  UWORD          wort;
  976.  REGISTER UWORD i,j;
  977.  REGISTER ULONG o;
  978.  
  979.  hd->MenuPageCount=0;
  980.  o=MOFFSET(num);
  981.  if(o!=0)
  982.   {
  983.    CacheSeek(hd,o,OFFSET_BEGINNING);
  984.    CacheRead(hd,&wort,2L);
  985.    while((wort!=0xFFFF)&&(hd->MenuPageCount<=hd->MaxItems))
  986.     {
  987.      hd->MenuPages[hd->MenuPageCount]=wort;
  988.      hd->MenuPageCount++;
  989.      CacheRead(hd,&wort,2L);
  990.     }
  991.    for(j=0;j<hd->MenuPageCount;j++)
  992.     {
  993.      if(hd->MenuPages[j]!=2000)
  994.       {
  995.        GetTitle(hd,hd->MenuPages[j]);
  996.        if((strlen(hd->Memory))>59) hd->Memory[59]=0x00;
  997.        strcpy(&hd->MenuNames[j],hd->Memory);
  998.       }
  999.     }
  1000.   }
  1001. }
  1002.  
  1003.  
  1004. /* Textseite anzeigen */
  1005. VOID ShowTextPage(hd,num)
  1006.  struct HelpData *hd;
  1007.  UWORD            num;
  1008. {
  1009.  REGISTER UWORD  i,j;
  1010.  
  1011.  GetPictures(hd,num);
  1012.  GetItems(hd,num);
  1013.  MakeMenu(hd);
  1014.  
  1015.  RefreshGadWindow(hd);
  1016.  hd->CurrentLine=0xFFFF;
  1017.  hd->LineCount=0;
  1018.  
  1019.  j=LENGTH(num);
  1020.  CacheSeek(hd,TOFFSET(num),OFFSET_BEGINNING);
  1021.  CacheRead(hd,hd->Memory,j);
  1022.  
  1023.  i=0;
  1024.  while(i<j)
  1025.  {
  1026.   hd->Lines[hd->LineCount]=&hd->Memory[i];
  1027.   i+=(strlen(&hd->Memory[i])+1);
  1028.   hd->LineCount++;
  1029.  }
  1030.  
  1031.  ShowPart(hd,0);
  1032.  
  1033.  if(hd->LineCount>hd->Rows)
  1034.    hd->PropBody=hd->LineCount-hd->Rows;
  1035.  else
  1036.    hd->PropBody=1;
  1037.  NewProp(hd,hd->PropBody);
  1038.  WindowToFront(hd->TextWindow);
  1039. }
  1040.  
  1041.  
  1042. /* Textteil auflisten */
  1043. VOID ShowPart(hd,part)
  1044.  struct HelpData *hd;
  1045.  UWORD            part;
  1046. {
  1047.  UBYTE          s[6];
  1048.  REGISTER BYTE  test;
  1049.  REGISTER UWORD i,j,k;
  1050.  
  1051.  if(part==hd->CurrentLine) return;
  1052.  
  1053.  ConWrite(hd,"\x9b0;33;40m");
  1054.  if(!(hd->LineCount<=hd->Rows))
  1055.   {
  1056.    if(part>(hd->LineCount-hd->Rows)) part=hd->LineCount-hd->Rows;
  1057.  
  1058.    /*  part            = Zeile, ab der gelistet werden soll
  1059.        hd->CurrentLine = Zeile, ab der gelistet wird          */
  1060.  
  1061.    if(part>hd->CurrentLine)
  1062.      { test=3; if(part-hd->CurrentLine>=hd->Rows) test=1; }
  1063.    else if(part<hd->CurrentLine)
  1064.      { test=4; if(hd->CurrentLine-part>=hd->Rows) test=1; }
  1065.    else if(part==hd->CurrentLine)
  1066.      { test=1; }
  1067.  
  1068.    switch(test)
  1069.     {
  1070.      case 1:
  1071.        hd->CurrentLine=part;
  1072.        ConWrite(hd,"\f");
  1073.        for(i=part;i<part+hd->Rows;i++)
  1074.         {
  1075.          ConWrite(hd,hd->Lines[i]);
  1076.          ConWrite(hd,"\n");
  1077.         }
  1078.       break;
  1079.      case 3:
  1080.        j=part-hd->CurrentLine;
  1081.        k=hd->CurrentLine+hd->Rows;
  1082.        for(i=k;i<(k+j);i++)
  1083.         {
  1084.          ConWrite(hd,hd->Lines[i]);
  1085.          ConWrite(hd,"\n");
  1086.         }
  1087.        hd->CurrentLine+=j;
  1088.       break;
  1089.      case 4:
  1090.        j=hd->CurrentLine-part;
  1091.        k=hd->CurrentLine;
  1092.        ConWrite(hd,"\x9b");
  1093.        ConWrite(hd,"H");
  1094.        for(i=(k-j);i<k;i++)
  1095.         {
  1096.          ConWrite(hd,"\x9b");
  1097.          ConWrite(hd,"L");
  1098.          ConWrite(hd,hd->Lines[i]);
  1099.          ConWrite(hd,"\n");
  1100.         }
  1101.        sprintf(&s,"%ldH",(hd->Rows+1));
  1102.        ConWrite(hd,"\x9b");
  1103.        ConWrite(hd,&s);
  1104.        ConWrite(hd,"\x9b");
  1105.        ConWrite(hd,"M");
  1106.        hd->CurrentLine-=j;
  1107.       break;
  1108.     }
  1109.   }
  1110.  else
  1111.   {
  1112.    ConWrite(hd,"\f");
  1113.    for(i=0;i<hd->LineCount;i++)
  1114.     {
  1115.      ConWrite(hd,hd->Lines[i]);
  1116.      ConWrite(hd,"\n");
  1117.     }
  1118.   }
  1119. }
  1120.  
  1121.  
  1122. /* Index-Gadgets entfernen */
  1123. VOID RemIndexGadgets(hd)
  1124.  struct HelpData *hd;
  1125. {
  1126.  UBYTE          i;
  1127.  struct Gadget *gad;
  1128.  
  1129.  for(i=0;i<64;i++)
  1130.   {
  1131.    gad=hd->IndexGadgets[i];
  1132.    if(gad!=NULL)
  1133.     {
  1134.      RemoveGadget(hd->IndexWindow,gad);
  1135.      hd->IndexGadgets[i]=NULL;
  1136.      hd->IndexGadgetPages[i]=0;
  1137.     }
  1138.   }
  1139.  if(hd->IndexWindow->UserData!=NULL)
  1140.   {
  1141.    FreeRemember(&hd->IndexWindow->UserData,TRUE);
  1142.    hd->IndexWindow->UserData=NULL;
  1143.   }
  1144.  SetAPen(hd->IndexRastPort,0);
  1145.  RectFill(hd->IndexRastPort,0,0,582,210);
  1146. }
  1147.  
  1148.  
  1149. /* Proportionalgadget verändern */
  1150. VOID NewProp(hd,v)
  1151.  struct HelpData *hd;
  1152.  UWORD            v;
  1153. {
  1154.  
  1155.  ModifyProp(hd->PropGadget,hd->MainWindow,NULL,
  1156.             AUTOKNOB|PROPBORDERLESS|FREEVERT,0,0,0,65535/v);
  1157. }
  1158.  
  1159.  
  1160. /* Menüleiste erstellen */
  1161. VOID MakeMenu(hd)
  1162.  struct HelpData *hd;
  1163. {
  1164.  REGISTER UWORD i,j;
  1165.  
  1166.  RemoveMenuStrip(hd->MenuStrip,FALSE);
  1167.  hd->DateiMenu=AddMenu(hd->MenuStrip,"Datei",5,150);
  1168.  AddItem(hd->MenuStrip,"Einstellunden ändern",300,'E',TRUE,TRUE);
  1169.  AddItem(hd->MenuStrip,GetOpalLine(),300,0,FALSE,FALSE);
  1170.  AddItem(hd->MenuStrip,"Bedienungshinweise",300,'B',TRUE,TRUE);
  1171.  AddItem(hd->MenuStrip,"Statistik",300,'S',TRUE,TRUE);
  1172.  AddItem(hd->MenuStrip,"Testseite",300,'T',TRUE,TRUE);
  1173.  AddItem(hd->MenuStrip,GetOpalLine(),300,0,FALSE,FALSE);
  1174.  AddItem(hd->MenuStrip,"Information",300,'I',TRUE,TRUE);
  1175.  AddItem(hd->MenuStrip,GetOpalLine(),300,0,FALSE,FALSE);
  1176.  AddItem(hd->MenuStrip,"Hilfe beenden",300,'Q',TRUE,TRUE);
  1177.  hd->QVMenu=AddMenu(hd->MenuStrip,"Querverweise",160,150);
  1178.  if(hd->MenuPageCount>0)
  1179.   {
  1180.    for(i=0;i<hd->MenuPageCount;i++)
  1181.     {
  1182.      if(hd->MenuPages[i]!=2000)
  1183.       {
  1184.        MacFormat(hd->MainRastPort,&hd->MenuNames[i],430);
  1185.        AddItem(hd->MenuStrip,&hd->MenuNames[i],450,0,TRUE,TRUE);
  1186.       }
  1187.      else AddItem(hd->MenuStrip,GetOpalLine450(),450,0,FALSE,FALSE);
  1188.     }
  1189.   }
  1190.  else AddItem(hd->MenuStrip,"Nicht verfügbar",300,0,TRUE,FALSE);
  1191.  hd->BilderMenu=AddMenu(hd->MenuStrip,"Bilder",315,150);
  1192.  if(hd->MenuPicCount>0)
  1193.   {
  1194.    for(i=0;i<hd->MenuPicCount;i++)
  1195.     {
  1196.      if(hd->MenuPics[i]!=200)
  1197.       {
  1198.        sprintf(&hd->MenuPicNames[i],"Abbildung #%ld",hd->MenuPics[i]+1);
  1199.        AddItem(hd->MenuStrip,&hd->MenuPicNames[i],300,0,TRUE,TRUE);
  1200.       }
  1201.      else AddItem(hd->MenuStrip,GetOpalLine(),300,0,FALSE,FALSE);
  1202.     }
  1203.   }
  1204.  else AddItem(hd->MenuStrip,"Nicht verfügbar",300,0,TRUE,FALSE);
  1205.  UseMenuStrip(hd->MenuStrip);
  1206.  ActivateWindow(hd->MainWindow);
  1207. }
  1208.  
  1209.  
  1210. UBYTE *HString[]=
  1211. {
  1212.  "",
  1213.  "\x9b1;33;40m\x9b4;33;40mDie Bedienung des Online-Hilfesystems\x9b0;33;40m",
  1214.  "",
  1215.  "",
  1216.  "",
  1217.  "\x9b4;33;40mDie Auswahl von Seiten\x9b0;33;40m",
  1218.  "",
  1219.  "",
  1220.  "Beim Aufruf des Hilfesystems wird zuerst der Hauptindex geladen. Durch",
  1221.  "Klicken auf die Gadgets im Index gelangt man zu den entsprechenden",
  1222.  "Seiten.",
  1223.  "",
  1224.  "Am unteren Bildschirmrand befindet sich mindestens ein Gadget; maximal",
  1225.  "jedoch sechs. Mit ihnen kann zur nächsten bzw. vorhergehenden Seite ge-",
  1226.  "wechselt werden oder die zuletzt angezeigten Seiten erneut sichten.",
  1227.  "",
  1228.  "Gadget-Positionen und ihre Funktionen",
  1229.  "",
  1230.  "[«] [......] [......] [......] [......] [»]",
  1231.  " |     |        |        |        |      |",
  1232.  " |     |        |        |        |      +-- Umkehrung von \"«\"",
  1233.  " |     |        |        |        +-- nächste Indexseite",
  1234.  " |     |        |        +-- nächste Textseite",
  1235.  " |     |        +-- vorhergehende Textseite",
  1236.  " |     +-- vorhergehende Indexseite",
  1237.  " +-- zuletzt gezeigte Seite sichten",
  1238.  "",
  1239.  "",
  1240.  "",
  1241.  "\x9b4;33;40mDie Seitentypen\x9b0;33;40m",
  1242.  "",
  1243.  "",
  1244.  "Indexseiten:",
  1245.  "",
  1246.  "Auf Indexseiten befinden sich Gadgets, die zu den entsprechenden Text-",
  1247.  "seiten führen.",
  1248.  "",
  1249.  "",
  1250.  "Textseiten:",
  1251.  "",
  1252.  "Auf diesen Seiten stehen die Hilfstexte. Ist der Text größer als der",
  1253.  "im Textfenster zur Verfügung stehende Platz, so läßt sich der Text-",
  1254.  "ausschnitt mit dem Proportional-Gadget am rechten Bildschirmrand ver-",
  1255.  "schieben.",
  1256.  "",
  1257.  "Besitzt die Seite Querverweise auf andere Seiten, so sind diese im",
  1258.  "Menü \"Querverweise\" aufgelistet. Durch Anwahl des entsprechenden",
  1259.  "Menüpunktes wird die Seite geladen.",
  1260.  "Gleiches gilt für Bilder und Diagramme im Menü \"Bilder\".",
  1261.  "",
  1262.  "",
  1263.  "",
  1264.  "\x9b4;33;40mDas Datei-Menü\x9b0;33;40m",
  1265.  "",
  1266.  "",
  1267.  "Der Menüpunkt \"Einstellungen ändern\"",
  1268.  "",
  1269.  "Hier lassen sich die Grundeinstellungen des Hilfesystems ändern:",
  1270.  "",
  1271.  "Cache-Modus: Die Hilfedatei wird beim Start komplett in den Haupt-",
  1272.  "             speicher geladen. Bei Systemen mit wenig Speicher kann",
  1273.  "             der Modus ausgeschaltet werden. Bei jeder neuen Seite",
  1274.  "             wird dann vom Datenträger nachgeladen.",
  1275.  "",
  1276.  "PAL-Modus: Es wird statt des amerikanischen NTSC-Videosystems",
  1277.  "           (600x200 Pixel) das europäische PAL-System (640x256 Pixel)",
  1278.  "           benutzt."
  1279.  "",
  1280.  "Seitennummern: Zusätzlich zum Seitentitel wird auch die Seitennummer",
  1281.  "               angezeigt. Über diese Nummern läuft die gesamte Seiten-",
  1282.  "               verwaltung; deshalb kann diese Funktion beim Einbau der",
  1283.  "               Online-Hilfe in eigene Programme sinnvoll sein. Für den",
  1284.  "               normalen Gebrauch werden diese Nummern nicht benötigt,",
  1285.  "               da die Seitenauswahl über die Maus läuft.",
  1286.  "",
  1287.  "SN-Eingabe: Ist diese Funktion eingeschaltet, so kann eine Seitennummer",
  1288.  "            direkt eingegeben werden: Wurde die erste Ziffer gedrückt,",
  1289.  "            so erscheint rechts oben neben dem Index-Gadget statt der",
  1290.  "            Seitentitelanzeige die Nummerneingabeanzeige. Die direkte",
  1291.  "            Seiteneingabe ist wie auch die Seitennummernanzeige nur",
  1292.  "            für Entwicklungszwecke gedacht und wird deshalb bei Nor-",
  1293.  "            malgebrauch nicht benötigt.",
  1294.  "",
  1295.  "",
  1296.  "Der Menüpunkt \"Bedienungshinweise\"",
  1297.  "",
  1298.  "Hiermit wird dieser Text angezeigt.",
  1299.  "",
  1300.  "",
  1301.  "Der Menüpunkt \"Information\"",
  1302.  "",
  1303.  "Hiermit werden Informationen über das Hilfesystem, die Version und",
  1304.  "den noch freien Speicher im Amiga und auf einer eventuell vorhan-",
  1305.  "denen PC/AT-Brückenkarte angezeigt.",
  1306.  "",
  1307.  "",
  1308.  "Der Menüpunkt \"Hilfe beenden\"",
  1309.  "",
  1310.  "Hiermit wird das Hilfesystem geschlossen und in das Anwendungs-",
  1311.  "programm zurückgekehrt, von welchem das Hilfesystem aufgerufen",
  1312.  "wurde.",
  1313.  "",
  1314.  "",
  1315.  "",
  1316.  "\x9b4;33;40mDas Querverweise-Menü\x9b0;33;40m",
  1317.  "",
  1318.  "In diesem Menü stehen Querverweise auf andere, zum Thema relevante",
  1319.  "Seiten. Sie können durch Anwahl des entsprechendes Menüpunktes",
  1320.  "gesichtet werden. Querverweise sind nicht auf allen Seiten.",
  1321.  "",
  1322.  "",
  1323.  "",
  1324.  "\x9b4;33;40mDas Bilder-Menü\x9b0;33;40m",
  1325.  "",
  1326.  "In diesem Menü befinden sich Bilder, die durch Anwahl der Menüpunkte",
  1327.  "angezeigt werden. Bilder sind, wie Querverweise, nicht auf allen",
  1328.  "Seiten.",
  1329.  NULL
  1330. };
  1331.  
  1332. UBYTE *TString[]=
  1333. {
  1334.  "",
  1335.  "\x9b4;33;40mTestseite für das \x9b1;33;40mOnline-Help-System\x9b0;33;40m",
  1336.  "",
  1337.  "",
  1338.  "Diese Seite dient dazu, die gestalterischen Möglichkeiten aufzuzeigen,",
  1339.  "die mit diesem System möglich sind:",
  1340.  "",
  1341.  " - \x9b4;33;40mUnterstreichen\x9b;0;33;40m",
  1342.  " - \x9b1;33;40mFettdruck\x9b;0;33;40m",
  1343.  " - \x9b3;33;40mKursiv\x9b;0;33;40m",
  1344.  " - \x9b4;33;40mInvers\x9b;0;33;40m",
  1345.  " - F\x9b0;34;40ma\x9b0;35;40mr\x9b0;36;40mb\x9b0;37;40me\x9b0;38;40mn",
  1346.  " - \x9b0;35;40mund \x9b1;36;40mnatürlich \x9b3;37;40mauch \x9b4;34;40m\x9b3;34;40mKombinationen\x9b0;33;40m"
  1347.  "",
  1348.  "",
  1349.  "",
  1350.  "Weitere Informationen zur Programmierung finden Sie in der Dokumentation",
  1351.  "der ATUtilities-Library!",
  1352.  "",
  1353.  "",
  1354.  "",
  1355.  NULL
  1356. };
  1357.  
  1358. UBYTE *Test="\x9b%d;%d;%dm Farbe %d: ABCEFGHIJKLMNOPQRSTUVWXYZ abcdefghijhklmnopqrstuvwxyz\x9b0;33;40m";
  1359.  
  1360. VOID Out(hd,text,a,b,c,d,e)
  1361.  struct HelpData *hd;
  1362.  UBYTE           *text;
  1363.  ULONG            a,b,c,d;
  1364. {
  1365.  sprintf(&hd->Memory[hd->OutputPos],text,a,b,c,d,e);
  1366.  hd->Lines[hd->LineCount]=&hd->Memory[hd->OutputPos];
  1367.  hd->LineCount++;
  1368.  hd->OutputPos+=strlen(&hd->Memory[hd->OutputPos])+2;
  1369. }
  1370.  
  1371.  
  1372. /* Sonderseiten */
  1373. VOID Special(hd,num)
  1374.  struct HelpData *hd;
  1375.  UBYTE            num;
  1376. {
  1377.  REGISTER UBYTE *t;
  1378.  REGISTER UBYTE  x;
  1379.  REGISTER ULONG  q;
  1380.  REGISTER UWORD  i,p;
  1381.  
  1382.  WindowToFront(hd->TextWindow);
  1383.  hd->Flags=PAGE_TEXT;
  1384.  hd->Page=1001;
  1385.  hd->LineCount=0;
  1386.  hd->OutputPos=1024;
  1387.  hd->CurrentLine=0xFFFF;
  1388.  i=0;
  1389.  
  1390.  ConWrite(hd,"\x9b0;33;40m\f");
  1391.  switch(num)
  1392.   {
  1393.    case 1:
  1394.      while(TString[i]!=NULL)
  1395.       {
  1396.        hd->Lines[i]=TString[i];
  1397.        i++;
  1398.       }
  1399.      hd->LineCount=i;
  1400.      for(p=0;p<5;p++)
  1401.       {
  1402.        Out(hd,"",0,0,0,0,0);
  1403.        for(i=0;i<=7;i++)
  1404.         {
  1405.          if(i==0) x=41; else x=40;
  1406.          Out(hd,Test,st[p],i+30,x,i);
  1407.         }
  1408.       }
  1409.     break;
  1410.    case 2:
  1411.      Out(hd,"",0,0,0,0,0);
  1412.      Out(hd,"\x9b1;33;40m\x9b4;33;4mStatistik\x9b0;33;40m",0,0,0,0,0);
  1413.      Out(hd,"",0,0,0,0,0);
  1414.      Out(hd,"",0,0,0,0,0);
  1415.      Out(hd,"\x9b4;33;40mSeitenübersicht\x9b0;33;40m",0,0,0,0,0);
  1416.      Out(hd,"",0,0,0,0,0);
  1417.      p=0; q=0;
  1418.      Out(hd,"Seite      Offset     Länge      Typ      Titel",0,0,0,0);
  1419.      for(i=0;i<1000;i++)
  1420.       {
  1421.        if(OFFSET(i)!=0)
  1422.         {
  1423.          if(FLAGS(i)==PAGE_INDEX) t="Index"; else t="Text";
  1424.          GetTitle(hd,i);
  1425.          Out(hd," %03ld       %6lx     %5ld      %s      %s",(ULONG)i,(ULONG)OFFSET(i),(ULONG)LENGTH(i),(ULONG)t,&hd->Memory);
  1426.          p++; q+=LENGTH(i);
  1427.         }
  1428.       }
  1429.      Out(hd,"",0,0,0,0,0);
  1430.      Out(hd,"",0,0,0,0,0);
  1431.      Out(hd,"Anzahl der Seiten:       %3ld",p,0,0,0,0);
  1432.      Out(hd,"Gesamter Text in KBytes: %3ld",q/1024,0,0,0,0);
  1433.      Out(hd,"",0,0,0,0,0);
  1434.      Out(hd,"",0,0,0,0,0);
  1435.      Out(hd,"\x9b4;33;40mBilderübersicht\x9b0;33;40m",0,0,0,0,0);
  1436.      Out(hd,"",0,0,0,0,0);
  1437.      Out(hd,"Bild          Offset",0,0,0,0,0);
  1438.      p=0;
  1439.      for(i=0;i<100;i++)
  1440.       {
  1441.        if(hd->Picture[i]!=0)
  1442.         {
  1443.          Out(hd," %02ld           %6lx",i,hd->Picture[i],0,0,0); p++;
  1444.         }
  1445.       }
  1446.      Out(hd,"",0,0,0,0,0);
  1447.      Out(hd,"",0,0,0,0,0);
  1448.      Out(hd,"Anzahl der Bilder:       %2ld",p,0,0,0,0);
  1449.     break;
  1450.    case 3:
  1451.      while(HString[i]!=NULL)
  1452.       {
  1453.        hd->Lines[i]=HString[i];
  1454.        i++;
  1455.       }
  1456.      hd->LineCount=i;
  1457.     break;
  1458.   }
  1459.  
  1460.  ShowPart(hd,0);
  1461.  if(hd->LineCount>hd->Rows)
  1462.    hd->PropBody=hd->LineCount-hd->Rows;
  1463.  else
  1464.    hd->PropBody=1;
  1465.  NewProp(hd,hd->PropBody);
  1466.  RemIndexGadgets(hd);
  1467. }
  1468.  
  1469.  
  1470. /* Einstellungen ändern */
  1471. VOID Prefs(hd)
  1472.  struct HelpData *hd;
  1473. {
  1474.  REGISTER UWORD                i,j;
  1475.  register struct FileHandle   *fh;
  1476.  register struct Window       *win;
  1477.  register struct RastPort     *rp;
  1478.  register struct Gadget       *g1,*g2,*g3,*g4;
  1479.  static struct NewWindow PrefsWindowDef=
  1480.   {
  1481.    75,75,450,90,
  1482.    0,1,
  1483.    CLOSEWINDOW,
  1484.    ACTIVATE|WINDOWDRAG|WINDOWCLOSE,
  1485.    NULL,NULL,"Online-Hilfe - Einstellungen",NULL,NULL,
  1486.    10,16,640,256,
  1487.    CUSTOMSCREEN
  1488.   };
  1489.  
  1490.  PrefsWindowDef.Screen=hd->Screen;
  1491.  win=OpenWindow(&PrefsWindowDef);
  1492.  if(win!=NULL)
  1493.   {
  1494.    win->UserData=NULL;
  1495.    rp=win->RPort;
  1496.    SetFont(rp,hd->OpalFont);
  1497.    if(hd->OHPrefs.Cache==0)
  1498.      g1=CreateNToggleGadget(win,15,15,410,12,"Cache für Hilfedatei anlegen",1);
  1499.    else
  1500.      g1=CreateSToggleGadget(win,15,15,410,12,"Cache für Hilfedatei anlegen",1);
  1501.    if(hd->OHPrefs.PAL==0)
  1502.      g4=CreateNToggleGadget(win,15,30,410,12,"Europäisches PAL-Videosystem",4);
  1503.    else
  1504.      g4=CreateSToggleGadget(win,15,30,410,12,"Europäisches PAL-Videosystem",4);
  1505.    SetAPen(rp,3);
  1506.    WriteText(rp,20,52,"Spezialeinstellungen:");
  1507.    if(hd->OHPrefs.Numbers==0)
  1508.      g2=CreateNToggleGadget(win,15,57,410,12,"Anzeige mit Seitennummern",2);
  1509.    else
  1510.      g2=CreateSToggleGadget(win,15,57,410,12,"Anzeige mit Seitennummern",2);
  1511.    if(hd->OHPrefs.NumInput==0)
  1512.      g3=CreateNToggleGadget(win,15,72,410,12,"Direkte Seitennummereingabe",3);
  1513.    else
  1514.      g3=CreateSToggleGadget(win,15,72,410,12,"Direkte Seitennummereingabe",3);
  1515.    WaitPort(win->UserPort);
  1516.    ReplyMsg(GetMsg(win->UserPort));
  1517.    if(g1->Flags & SELECTED) hd->OHPrefs.Cache=1; else hd->OHPrefs.Cache=0;
  1518.    if(g2->Flags & SELECTED) hd->OHPrefs.Numbers=1; else hd->OHPrefs.Numbers=0;
  1519.    if(g3->Flags & SELECTED) hd->OHPrefs.NumInput=1; else hd->OHPrefs.NumInput=0;
  1520.    if(g4->Flags & SELECTED) hd->OHPrefs.PAL=1; else hd->OHPrefs.PAL=0;
  1521.    DeleteStdWindow(win);
  1522.    fh=Open(HelpName,MODE_NEWFILE);
  1523.    if(fh!=NULL)
  1524.     {
  1525.      Write(fh,&hd->OHPrefs,sizeof(struct OHPrefs));
  1526.      Close(fh);
  1527.     }
  1528.   }
  1529. }
  1530.  
  1531.  
  1532. /* Read-Funktion für Cache */
  1533. LONG CacheRead(hd,mem,len)
  1534.  struct HelpData *hd;
  1535.  UBYTE           *mem;
  1536.  ULONG            len;
  1537. {
  1538.  
  1539.  if(hd->CacheOn==0)
  1540.   {
  1541.    return(Read(hd->HelpFile,mem,len));
  1542.   }
  1543.  
  1544.  CopyMem(&hd->CacheMemory[hd->CachePos],mem,len);
  1545.  hd->CachePos+=len;
  1546.  return(len);
  1547. }
  1548.  
  1549.  
  1550. /* Seek-Funktion für Cache */
  1551. LONG CacheSeek(hd,pos,offset)
  1552.  struct HelpData *hd;
  1553.  LONG             pos;
  1554.  LONG             offset;
  1555. {
  1556.  
  1557.  if(hd->OHPrefs.Cache==0)
  1558.   {
  1559.    return(Seek(hd->HelpFile,pos,offset));
  1560.   }
  1561.  
  1562.  hd->CacheLastPos=hd->CachePos;
  1563.  switch(offset)
  1564.   {
  1565.    case OFFSET_BEGINNING:
  1566.      hd->CachePos=pos;
  1567.     break;
  1568.    case OFFSET_END:
  1569.      hd->CachePos=hd->CacheSize+pos;
  1570.     break;
  1571.   }
  1572.  return(hd->CacheLastPos);
  1573. }
  1574.  
  1575.  
  1576. /* IFF-Bild zeigen */
  1577. VOID LoadAPicture(hd,num)
  1578.  struct HelpData *hd;
  1579.  UBYTE            num;
  1580. {
  1581.  LONG                        o;
  1582.  ULONG                       size;
  1583.  UBYTE                       byte;
  1584.  REGISTER BOOL               bool;
  1585.  REGISTER UBYTE             *mem;
  1586.  register struct FileHandle *fh;
  1587.  
  1588.  o=hd->Picture[num];
  1589.  if(o!=NULL)
  1590.   {
  1591.    CacheSeek(hd,o,OFFSET_BEGINNING);
  1592.    CacheRead(hd,&byte,1L);
  1593.    if(byte==0)
  1594.     {
  1595.      CacheRead(hd,&hd->String,199);
  1596.      hd->String[199]=0x00;
  1597.      bool=ShowPicture(&hd->String);
  1598.      if(bool==FALSE)
  1599.        MultiRequest("Bild kann nicht geladen werden:",&hd->String,"Okay",0L);
  1600.     }
  1601.    else
  1602.     {
  1603.      CacheRead(hd,&size,4L);
  1604.      if(hd->CacheOn!=0)
  1605.       {
  1606.        DisplayPicture(&hd->CacheMemory[hd->CachePos],size);
  1607.       }
  1608.      else
  1609.       {
  1610.        mem=AllocMem(size,MEMF_CLEAR|MEMF_PUBLIC);
  1611.        if(mem!=NULL)
  1612.         {
  1613.          CacheRead(hd,mem,size);
  1614.          DisplayPicture(mem,size);
  1615.          FreeMem(mem,size);
  1616.         }
  1617.       }
  1618.     }
  1619.   }
  1620. }
  1621.  
  1622.  
  1623. /* Seite in Seitenliste einfügen */
  1624. VOID AddPage(hd)
  1625.  struct HelpData *hd;
  1626. {
  1627.  REGISTER UBYTE i;
  1628.  
  1629.  hd->ShowLastPageBack=0;
  1630.  hd->LastPageSelect=hd->LastPagePos;
  1631.  if(hd->LastPagePos<PAGE_MEMORY)
  1632.   {
  1633.    hd->LastPage[hd->LastPagePos]=hd->Page;
  1634.    hd->LastPagePos++;
  1635.   }
  1636.  else
  1637.   {
  1638.    for(i=0;i<PAGE_MEMORY;i++)
  1639.     {
  1640.      hd->LastPage[i]=hd->LastPage[i+1];
  1641.     }
  1642.    hd->LastPage[PAGE_MEMORY-1]=hd->Page;
  1643.    hd->LastPageSelect=PAGE_MEMORY-1;
  1644.   }
  1645. }
  1646.  
  1647.